﻿Imports DTO
Imports BUS


Public Class frmCapNhatBoPhan : Inherits DevComponents.DotNetBar.Office2007Form
    ' Hàm reset
    Private Sub Reset()
        'txtTenBangCap.Text = ""
        txtMaBoPhan.Text = ""
        txtTenBoPhanMoi.Text = ""
    End Sub

    ' Hàm kiểm tra dữ liệu khi thêm
    Private Function KiemTraDuLieuThem() As Boolean
        Return txtTenBoPhan.Text <> ""
    End Function

    ' Khi nhấn nút Thoát
    Private Sub btnThoat_Click(ByVal sender As System.Object, ByVal e As System.EventArgs)
        Me.Close()
    End Sub

    ' Hàm thực hiện thêm bằng cấp
    Private Sub btnThem_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnThem.Click
        If KiemTraDuLieuThem() Then
            Dim kt As Integer = New CBoPhanBUS().ThemBoPhan(txtTenBoPhan.Text)
            If (kt = (-1)) Then
                MessageBox.Show("Số bộ phận không được vượt quá số lượng quy định", "Thong Bao")
                txtTenBoPhan.Text = ""
                Return
            Else
                If (kt = 0) Then
                    MessageBox.Show("Tên bộ phận này đã tồn tại!", "Thong Bao")
                    txtTenBoPhan.Text = ""
                    Return
                Else
                    MessageBox.Show("Đã thêm thành công!", "Thong Bao")
                    txtTenBoPhan.Text = ""
                    Dim listbophan As List(Of CBoPhanDTO) = New CBoPhanBUS().LoadDanhSachBoPhan()
                    dgvDanhSachBoPhan.Rows.Clear()
                    stt = 1
                    For Each bophan As CBoPhanDTO In listbophan
                        dgvDanhSachBoPhan.Rows.Add(stt, bophan.Ma, bophan.Ten)
                        stt += 1
                    Next
                    Return
                End If
            End If
        Else
            MessageBox.Show("Dữ liệu không hợp lệ!", "Thong Bao")
            txtTenBoPhan.Focus()
            Return
        End If

    End Sub

    Private stt As Integer

    ' Hàm load
    Private Sub frmCapNhatBoPhan_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        stt = 1
        dtiNgayHienTai.Value = DateTime.Now
        ' Load danh sách bằng cấp vào trong datagridview:
        Dim listbophan As List(Of CBoPhanDTO) = New CBoPhanBUS().LoadDanhSachBoPhan()
        dgvDanhSachBoPhan.Rows.Clear()
        For Each bophan As CBoPhanDTO In listbophan
            dgvDanhSachBoPhan.Rows.Add(stt, bophan.Ma, bophan.Ten)
            stt += 1
        Next
    End Sub


    ' Xử lý khi chọn vào dòng nào trong datagridview thì ta load nó lên cập nhật:
    Private Sub dgvDanhSachBoPhan_CellClick(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs) Handles dgvDanhSachBoPhan.CellClick
        Dim index As Integer = e.RowIndex
        If index < 0 Then
            If txtMaBoPhan.Text <> "" Then
                Reset()
            End If
            Return
        End If

        If (index >= dgvDanhSachBoPhan.Rows.Count) Then
            If (txtMaBoPhan.Text <> "") Then
                Reset()
            End If
            Return
        End If

        Dim dr As DataGridViewRow = dgvDanhSachBoPhan.Rows(index)
        txtMaBoPhan.Text = dr.Cells("clMaBoPhan").Value
        txtTenBoPhanMoi.Text = dr.Cells("clTenBoPhan").Value

    End Sub


    Private Sub btnCapNhat_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnCapNhat.Click
        Dim bophan As New CBoPhanDTO()
        If (Not Integer.TryParse(txtMaBoPhan.Text, bophan.Ma)) Then
            MessageBox.Show("Cần chọn bộ  phận muốn cập nhật!", "Thong Bao")
            Return
        End If
        If (txtTenBoPhanMoi.Text = "") Then
            MessageBox.Show("Cần nhập tên bộ phận mới để cập nhật!", "Thong Bao")
            txtTenBoPhanMoi.Focus()
            Return
        End If

        bophan.Ten = txtTenBoPhanMoi.Text

        Dim bophanbus As New CBoPhanBUS()
        Dim kq As Integer = bophanbus.CapNhatBoPhan(bophan)
        If (kq = 0) Then
            MessageBox.Show("Tên bộ phận này đã có", "Thong Bao")
            Return
        Else
            MessageBox.Show("Đã cập nhật thành công!", "Thong Bao")
            Reset()
            dgvDanhSachBoPhan.Rows.Clear()
            Dim listbophan As List(Of CBoPhanDTO) = New CBoPhanBUS().LoadDanhSachBoPhan()
            stt = 1
            For Each bp As CBoPhanDTO In listbophan
                dgvDanhSachBoPhan.Rows.Add(stt, bp.Ma, bp.Ten)
                stt += 1
            Next
            Return
        End If

    End Sub

End Class